All files / app/pages/event/[id]/[slug] index.tsx

0% Statements 0/20
0% Branches 0/7
0% Functions 0/3
0% Lines 0/15

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43                                                                                     
import { appGetLayout } from "components/AppRoute";
import EventPageComponent from "features/communities/events/EventPage";
import NotFoundPage from "features/NotFoundPage";
import { appServerSideTranslations } from "i18n/appServerSideTranslations";
import {
  COMMUNITIES,
  GLOBAL,
  MESSAGES,
  NOTIFICATIONS,
  PROFILE,
} from "i18n/namespaces";
import { GetStaticPaths, GetStaticProps } from "next";
import { useRouter } from "next/router";
import stringOrFirstString from "utils/stringOrFirstString";
 
export const getStaticPaths: GetStaticPaths = () => ({
  paths: [],
  fallback: "blocking",
});
 
export const getStaticProps: GetStaticProps = async ({ locale }) => ({
  props: {
    ...(await appServerSideTranslations(locale ?? "en", [
      GLOBAL,
      COMMUNITIES,
      NOTIFICATIONS,
      PROFILE,
      MESSAGES,
    ])),
  },
});
 
export default function EventPage() {
  const router = useRouter();
 
  const parsedId = Number.parseInt(stringOrFirstString(router.query.id) ?? "");
  Iif (isNaN(parsedId)) return <NotFoundPage />;
  const slug = stringOrFirstString(router.query.slug) ?? "";
  return <EventPageComponent eventId={parsedId} eventSlug={slug} />;
}
 
EventPage.getLayout = appGetLayout();